<template>
  <!-- Excel 导入功能组件 -->
  <UploadExcel :on-success="handleSuccess" />
</template>

<script>
import { formatExcelDate } from '@/utils'
import { importEmployeeAPI } from '@/api'
export default {
  name: 'Excel',
  methods: {
    // 导入成功以后的回调函数
    async handleSuccess({ results, header }) {
      const userRelations = {
        '入职日期': 'timeOfEntry',
        '手机号': 'mobile',
        '姓名': 'username',
        '转正日期': 'correctionTime',
        '工号': 'workNumber',
        '部门': 'departmentName',
        '聘用形式': 'formOfEmployment'
      }
      const newArr = []
      results.forEach(item => {
        const newObj = {}
        Object.keys(item).forEach(key => {
          const enKey = userRelations[key] // 换出英文的 key 字符串
          if (enKey === 'timeOfEntry' || enKey === 'correctionTime') {
            newObj[enKey] = formatExcelDate(item[key])
          } else {
            newObj[enKey] = item[key] // 把中文对象对应的中文 key 的 value 取出,赋予给新对象的英文 key 后面
          }
        })
        // 上面循环完一次,组装一个英文 key 的完整对象
        newArr.push(newObj)
      })
      const res = await importEmployeeAPI(newArr)
      if (!res.success) return this.$message.error(res.message)
      this.$router.back()
      this.$message.success('操作成功')
      this.$router.push('/employees')
    }
  }
}
</script>

<style lang="scss" scoped></style>
